CLAIMS 

1 . An apparatus comprising: 
at least one processor; 

a memory coupled to the at least one processor; and 

an optimizer residing in the memory and executed by the at least one processor, 
the optimizer analyzing an expression and generating from the expression a graph that 
includes at least one node, the optimizer generating from the graph an execution plan for 
the expression, the execution plan comprising a plurality of execution plans that 
correspond to different portions of the graph. 

2. The apparatus of claim 1 wherein the plurality of execution plans are appended to 
corresponding nodes in the graph. 

3. The apparatus of claim 1 wherein the optimizer generates a new execution plan 
for the query by changing at least one of the plurality of execution plans, and by using an 
existing execution plan for each portion of the graph that is unaffected by the change. 

4. The apparatus of claim 1 wherein the graph further comprises a plurality of 
relations and a plurality of expressions. 
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5 . An apparatus comprising: 
at least one processor; 

a memory coupled to the at least one processor; 
a database residing in the memory; 

a database query optimizer residing in the memory and executed by the at least 
one processor, the database query optimizer processing a query to the database, the 
database query optimizer comprising: 

a graph builder that generates from the query a graph that includes at least 

one node; and 

an execution plan generator that generates from the graph an execution 
plan for the query, the execution plan comprising a plurality of execution plans 
that correspond to different portions of the graph. 

6. The apparatus of claim 5 wherein the execution plan generator appends the 
plurality of execution plans to corresponding nodes in the graph. 

7. The apparatus of claim 5 wherein the execution plan generator generates a new 
execution plan for the query by changing at least one of the plurality of execution plans, 
and by using an existing execution plan for each portion of the graph that is unaffected by 
the change. 

8. The apparatus of claim 5 wherein the graph further comprises a plurality of 
relations and a plurality of expressions in the query. 

9. The apparatus of claim 5 wherein the optimizer compares a plurality of execution 
plans that each functionally represent the query to estimate which of the plurality of 
execution plans will be executed in the least amount of time. 
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1 10. A method for evaluating an expression comprising the steps of: 

2 reading the expression; 

3 generating from the expression a graph that includes at least one node; 

4 generating from the graph an execution plan for the expression, the execution plan 

5 comprising a plurality of execution plans that correspond to different portions of the 

6 graph. 

1 11. The method of claim 1 0 further comprising the step of appending the plurality of 

2 execution plans to corresponding nodes in the graph. 

!«* 

q 112. The method of claim 1 0 further comprising the step of generating a new execution 

2 plan for the query by performing the steps of: 
*Q 3 changing at least one of the plurality of execution plans; and 

iff! 4 using an existing execution plan for each portion of the graph that is unaffected by 



* 5 the change. 

fU 

I j, 1 13. The method of claim 1 0 further comprising the step of comparing a plurality of 

w 2 execution plans that each functionally represent the query to determine which of the 

3 plurality of execution plans will likely be executed in the least amount of time. 



Docket No. ROC920010239US1 30 



1 4. A program product comprising: 

(A) an optimizer that analyzes an expression and generates from the expression a 
graph that includes at least one node, the optimizer generating from the graph an 
execution plan for the expression, the execution plan comprising a plurality of execution 
plans that correspond to different portions of the graph; and 

(B) computer-readable signal bearing media bearing the optimizer. 

15. The program product of claim 14 wherein the computer-readable signal bearing 
media comprises recordable media. 

16. The program product of claim 14 wherein the computer-readable signal bearing 
media comprises transmission media. 

1 7. The program product of claim 14 wherein the optimizer appends the plurality of 
execution plans to corresponding nodes in the graph. 

18. The program product of claim 1 4 wherein the optimizer generates a new 
execution plan for the query by changing at least one of the plurality of execution plans, 
and by using an existing execution plan for each portion of the graph that is unaffected by 
the change. 

1 9. The program product of claim 14 wherein the graph further comprises a plurality 
of relations and a plurality of expressions. 
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20. The program product of claim 14 wherein the optimizer compares a plurality of 
execution plans that each functionally represent the expression to estimate which of the 
plurality of execution plans will be executed in the least amount of time. 

* * * * * 
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